
<!DOCTYPE html>
<html lang="">


<head><meta name="generator" content="Hexo 3.8.0">
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1.0, user-scalable=no">
  <meta name="theme-color" content="#202020">
  <meta http-equiv="x-ua-compatible" content="ie=edge">
  <script src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js" async></script>
  
  
    <meta name="keywords" content>
  

  
    <meta name="description" content="前端性能优化问题">
  
  
  
  <link rel="icon" type="image/x-icon" href="/images/footer-logo.png">
  
  <title>前端性能优化问题 [ 51AIOps 专注于运维自动化  微信： kaipython ]</title>
  
    <!-- stylesheets list from config.yml -->
    
      <link rel="stylesheet" href="//cdn.bootcss.com/pure/1.0.0/pure-min.css">
    
      <link rel="stylesheet" href="/css/xoxo.css">
    
  
</head>


<body>
  <div class="nav-container">
    <nav class="home-menu pure-menu pure-menu-horizontal">
  <a class="pure-menu-heading" href="/">
    
    <span class="title" style="text-transform:none">51AIOps 专注于运维自动化  微信： kaipython</span>
  </a>

  <ul class="pure-menu-list clearfix">
      
          
            
              <li class="pure-menu-item"><a href="/" class="pure-menu-link">首页</a></li>
            
          
      
  </ul>
   
</nav>

  </div>

  <div class="container" id="content-outer">
    <div class="inner" id="content-inner" style='margin-left:-68px!important'>
      <div class="post-container">
  <article class="post" id="post">
    <header class="post-header text-center">
      <h1 class="title">
        前端性能优化问题
      </h1>
      <span>
        
        <time class="time" datetime="2016-10-24T08:47:15.000Z">
        2016-10-24
      </time>
        
      </span>
      <span class="slash">/</span>
      <span class="post-meta">
      <span class="post-tags">
        
      </span>
    </span>
      <span class="slash">/</span>
      <span class="read">
      <span id="busuanzi_value_page_pv"></span> 点击
    </span>
      <span class="slash">/</span>
    </header>

    <div class="post-content">
      <h3 id="前端优化的技巧"><a href="#前端优化的技巧" class="headerlink" title="前端优化的技巧"></a>前端优化的技巧</h3><h4 id="前言"><a href="#前言" class="headerlink" title="前言"></a><div id="title">前言</div></h4><p>这个问题无论是实际项目还是面试都是经常碰到的，所以非常有必要总结一下</p>
<p>下面分别从几个大的方面去分析一下前端性能优化，有些优化其实效果并不一定非常明显，但还是有必要知道。</p>
<h4 id="减少HTTP请求"><a href="#减少HTTP请求" class="headerlink" title="减少HTTP请求"></a><div id="title">减少HTTP请求</div></h4><p>尽可能减少加载一个页面需要引用的资源个数，因为每一次HTTP请求都是客户端与服务端的一次重连，都是一笔不小的开销，可以采取的措施包括：</p>
<h4 id="使用精灵图"><a href="#使用精灵图" class="headerlink" title="使用精灵图"></a><div id="title">使用精灵图</div></h4><p><code>CSS Sprites</code>，又叫雪碧图，将页面中多个小图合并一张大图，然后采用background-position来定位不同的图片。</p>
<h4 id="使用字体图标"><a href="#使用字体图标" class="headerlink" title="使用字体图标"></a><div id="title">使用字体图标</div></h4><p>对于一些简单的图标都可以采用字体图标来实现，一个几十kb的字体文件可以包含很多个图标，且可以随意设置颜色，无损放大。</p>
<p>如果你需要的只是少数几个图标，而字体文件比较大，还可以采用一些工具提取你所需要的那几个图标，然后重新导出一个更小的字体文件。</p>
<h4 id="合并JS和CSS"><a href="#合并JS和CSS" class="headerlink" title="合并JS和CSS"></a><div id="title">合并JS和CSS</div></h4><p>开发时可能引入了很多个单独的css和js文件，上线后可以利用前端构建工具将其合并成一个文件，这样能大大减少请求次数。</p>
<h4 id="合理使用域名"><a href="#合理使用域名" class="headerlink" title="合理使用域名"></a><div id="title">合理使用域名</div></h4><p>由于浏览器对于单个域名下的并发有最大连接限制（据说一般浏览器是6个），所以将静态资源分别放到不同的子域名下可以突破浏览器的并发限制，最大限度的利用带宽和资源。</p>
<p>但是，同一个网站使用的子域名也不是越多越好。域名既是个好东西，也是个坏东西。说它是个坏东西，是指当你没有恰当的使用它的时候。</p>
<p>当你在浏览器地址栏输入一个域名之后，浏览器首先需要将其解析成IP，然后再向服务器发起访问请求，这个解析的过程一般叫DNS解析。DNS解析是非常耗时的，特别是当你使用的是一些公共DNS解析服务的时候，有时候解析一个域名需要2-3s时间，甚至偶尔解析错误，导致你的网站根本访问不了！当你辛辛苦苦在其它方面优化提高了0.1s的访问速度时，一个DNS解析就让你的速度降低了数秒！</p>
<p>DNS解析拖慢网站访问速度主要体验在第一次访问的时候，当你第二次访问就很快了，因为浏览器会对DNS缓存。</p>
<p>综上，优化域名可以从以下几个方面出发：</p>
<ul>
<li>减少域名个数，同一个网页不要使用太多的子域名，一般建议不超过3个，每增加一个子域名都会大大拖慢你网站的初次访问速度；</li>
<li>更换更好的DNS服务商，免费的不好用就用收费的，舍不得孩子套不着狼；</li>
<li>如果网站域名映射已经稳定了，不会经常改动了，将TTL值设置为最大，它可以让你的DNS缓存更久；</li>
<li>如果网站不需要暴露网址给用户（比如内嵌APP形式），可以干脆不用域名，直接使用IP，当然这个要看个人喜好，用域名还是有一些好处的；</li>
</ul>
<h4 id="压缩"><a href="#压缩" class="headerlink" title=" 压缩"></a><div id="title"> 压缩</div></h4><p><strong>1.对大文件启用gzip</strong><br><strong>2.压缩JS和CSS</strong></p>
<blockquote>
<p>JS在开发时可能有大量的注释以及空格缩进等，压缩可以很好的减小文件体积，如果可以的话还可以混淆。</p>
</blockquote>
<blockquote>
<p>JS和CSS尽量写在单独的文件中，这样可以增加被缓存的机会，如果写在HTML中的话，只要地址不同浏览器就会认为是不同的网址，所以每次都需要重新加载这些JS和CSS。</p>
</blockquote>
<p><strong>3.JS的优化</strong></p>
<ul>
<li>减少DOM操作次数；</li>
<li>JS文件放置在文件底部；</li>
<li>上线后屏蔽一切日志代码，console.log对性能的影响还是比较大的</li>
</ul>
<p><strong>4.CSS的优化</strong></p>
<ul>
<li>减少内联样式的使用（style）；</li>
<li>css文件放在head中；</li>
<li>尽可能多的合并类似样式，比如如果2个class里面分别定义了10个CSS属性，其中只有1个不一样，那么就可以把这9个一样的拿出来写一个样式；</li>
<li>合并一些分开写的样式，比如border-width、border-style、border-color合并成border；</li>
<li>根据实际环境删除一些不必要的兼容性代码，比如如果你的项目只运行在移动端，那么诸如IE系列所有适配代码、-moz、-o等等这些玩意儿就不需要写了</li>
</ul>
<h4 id="图片优化"><a href="#图片优化" class="headerlink" title=" 图片优化"></a><div id="title"> 图片优化</div></h4><ul>
<li>减少图片的使用，能用CSS实现的效果优先使用CSS实现；</li>
<li>图片格式的选择，一般建议使用jpg，有透明需求再用png；</li>
<li>图片质量的控制，web上的图片质量不需要太高，上线时注意检查项目中是否有体积过大的图片；</li>
</ul>

    </div>

  </article>
  <div class="toc-container">
    
  <div id="toc" class="toc-article">
    <strong class="toc-title">目录</strong>
    <ol class="toc"><li class="toc-item toc-level-3"><a class="toc-link" href="#前端优化的技巧"><span class="toc-text">前端优化的技巧</span></a><ol class="toc-child"><li class="toc-item toc-level-4"><a class="toc-link" href="#前言"><span class="toc-text">前言</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#减少HTTP请求"><span class="toc-text">减少HTTP请求</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#使用精灵图"><span class="toc-text">使用精灵图</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#使用字体图标"><span class="toc-text">使用字体图标</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#合并JS和CSS"><span class="toc-text">合并JS和CSS</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#合理使用域名"><span class="toc-text">合理使用域名</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#压缩"><span class="toc-text"> 压缩</span></a></li><li class="toc-item toc-level-4"><a class="toc-link" href="#图片优化"><span class="toc-text"> 图片优化</span></a></li></ol></li></ol>
  </div>


  </div>
</div>
<script type="text/javascript" src="//rf.revolvermaps.com/0/0/8.js?i=5sr5du46f27&amp;m=0&amp;c=ff0000&amp;cr1=ffffff&amp;f=arial&amp;l=33" async="async"></script>
<div class="copyright">
    <span>本作品采用</span>
    <a href="https://creativecommons.org/licenses/by/4.0/">知识共享署名 4.0 国际许可协议</a>
    <span>进行许可。 转载时请注明原文链接。</span>
</div>


  
    <div class="post-nav" style="margin-left:-168px;">
      <div class="post-nav-item post-nav-next">
        
      </div>
  
      <div class="post-nav-item post-nav-prev">
          
          <a href="/2017/04/07/爬取链家二手房信息/" rel="prev" title="爬链家二手房数据">
            爬链家二手房数据
          </a>
          <span>〉</span>
        
      </div>
    </div>
  


	
	<div style="width:109%; margin-left:-144px" id="lv-container" data-id="city" data-uid="MTAyMC80OTg5NS8yNjM4Ng==">
	<script type="text/javascript">
   	   (function(d, s) {
       		var j, e = d.getElementsByTagName(s)[0];

       		if (typeof LivereTower === 'function') { return; }

       		j = d.createElement(s);
       		j.src = 'https://cdn-city.livere.com/js/embed.dist.js';
       		j.async = true;

       		e.parentNode.insertBefore(j, e);
   	   })(document, 'script');
	</script>
	<noscript> 为正常使用来必力评论功能请激活JavaScript</noscript>
        </div>
	



    </div>

    

  </div>
  <footer class="footer text-center">
    <div id="bottom-inner">
        <a class="bottom-item" href target="_blank">GitHub</a> |
        <a class="bottom-item" href>友情链接</a> |
        <a class="bottom-item" href="https://hexo.io" target="_blank">Powered by hexo</a> |
        <a class="bottom-item" href="https://github.com/fooying/hexo-theme-xoxo-plus" target="_blank">Theme xoxo-plus</a> |
        <a class="bottom-item" href="/atom.xml">订阅</a>
    </div>
</footer>

  

<script>
  (function(window, document, undefined) {

    var timer = null;

    function returnTop() {
      cancelAnimationFrame(timer);
      timer = requestAnimationFrame(function fn() {
        var oTop = document.body.scrollTop || document.documentElement.scrollTop;
        if (oTop > 0) {
          document.body.scrollTop = document.documentElement.scrollTop = oTop - 50;
          timer = requestAnimationFrame(fn);
        } else {
          cancelAnimationFrame(timer);
        }
      });
    }

    var hearts = [];
    window.requestAnimationFrame = (function() {
      return window.requestAnimationFrame ||
        window.webkitRequestAnimationFrame ||
        window.mozRequestAnimationFrame ||
        window.oRequestAnimationFrame ||
        window.msRequestAnimationFrame ||
        function(callback) {
          setTimeout(callback, 1000 / 60);
        }
    })();
    init();

    function init() {
      css(".heart{z-index:9999;width: 10px;height: 10px;position: fixed;background: #f00;transform: rotate(45deg);-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);}.heart:after,.heart:before{content: '';width: inherit;height: inherit;background: inherit;border-radius: 50%;-webkit-border-radius: 50%;-moz-border-radius: 50%;position: absolute;}.heart:after{top: -5px;}.heart:before{left: -5px;}");
      attachEvent();
      gameloop();
      addMenuEvent();
    }

    function gameloop() {
      for (var i = 0; i < hearts.length; i++) {
        if (hearts[i].alpha <= 0) {
          document.body.removeChild(hearts[i].el);
          hearts.splice(i, 1);
          continue;
        }
        hearts[i].y--;
        hearts[i].scale += 0.004;
        hearts[i].alpha -= 0.013;
        hearts[i].el.style.cssText = "left:" + hearts[i].x + "px;top:" + hearts[i].y + "px;opacity:" + hearts[i].alpha + ";transform:scale(" + hearts[i].scale + "," + hearts[i].scale + ") rotate(45deg);background:" + hearts[i].color;
      }
      requestAnimationFrame(gameloop);
    }

    /**
     * 给logo设置点击事件
     * 
     * - 回到顶部
     * - 出现爱心
     */
    function attachEvent() {
      var old = typeof window.onclick === "function" && window.onclick;
      var logo = document.getElementById("logo");
      if (logo) {
        logo.onclick = function(event) {
          returnTop();
          old && old();
          createHeart(event);
        }
      }
      
    }

    function createHeart(event) {
      var d = document.createElement("div");
      d.className = "heart";
      hearts.push({
        el: d,
        x: event.clientX - 5,
        y: event.clientY - 5,
        scale: 1,
        alpha: 1,
        color: randomColor()
      });
      document.body.appendChild(d);
    }

    function css(css) {
      var style = document.createElement("style");
      style.type = "text/css";
      try {
        style.appendChild(document.createTextNode(css));
      } catch (ex) {
        style.styleSheet.cssText = css;
      }
      document.getElementsByTagName('head')[0].appendChild(style);
    }

    function randomColor() {
      // return "rgb(" + (~~(Math.random() * 255)) + "," + (~~(Math.random() * 255)) + "," + (~~(Math.random() * 255)) + ")";
      return "#F44336";
    }

    function addMenuEvent() {
      var menu = document.getElementById('menu-main-post');
      if (menu) {
        var toc = document.getElementById('toc');
        if (toc) {
          menu.onclick = function() {
            if (toc) {
              if (toc.style.display == 'block') {
                toc.style.display = 'none';
              } else {
                toc.style.display = 'block';
              }
            }
          };
        } else {
          menu.style.display = 'none';
        }
      }
    }

  })(window, document);
</script>

  



  

</body>
</html>
